


COLOFON 
DAInamic verschijnt tweemaandelijks. 
abonnementsprijs is inbegrepen in de 
jaarlijkse contributie: 
750 Вег 50 Gld 50 Dm 
Bij toetreding worden de verschenen 
nummers van de jaargang toegezonden. 
DAInamic redactie: 

Dirk Bonné 

Freddy De Raedt 

Wilfried Hermans 

Jules Meulenbergs 

Jos Schepens 

Roger Theeuws 

Bruno Van Rompaey 

Jef Verwimp 


vormgeving :Ludo van Mechelen 


— y. x nT 


U wordt lid door storting van de 
contributie op nr406-3016141-33 van 
KREDIETBANK WESTMEERBEEK,via bank- 
instelling of POSTGIRO, 

Abonnement loopt van januari tot 


december. 


hu — K ... 


U kan telefonisch contact nemen op 
nr 016/698623. 





correspondentieadres: 
DAInamic 
Heide 98 

3171 WESTMEERBEEK 





BELGIE 





de pare maanden. 


Bijdragen zijn steeds welkom. 
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pijltje boven SE 94 
pijltje onder 8C 140 
volle blok FF 255 
verticale lijn A 10 
horizontale lijn B 11 
6 Рог. 11 jnen 10 23 
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8080 SIMULATOR (2) 





Because the instructions are executed by 8080, some of them 
can have a funest effect on the program, these should not be 
used. These instructions are indicated by "*" in table l. 
Of cause, you could use CALL if there is some ml program 


somewhere in memory | 





INSTRUCTION FUNCTION HEX TABLE 1 INSTRUCTION FUNCTION HEX 
MOVE GROUP reg A B C D E H L М JUMP GROUP 
MOV A, reg (A reg TF 78 79 ТА ТВ TC 7D TE JMP adar, (PC)--adàr CZ al ah 
MOV B, reg B reg 47 40 41 42 43 44 45 46 JNZ addr, If 250, (PC )-addr 02 al ah 
MOV С, reg с reg 4F 48 49 4A 4B 4С 4D 4E JZ addr If 741, (PC)--addr CA al ah 
Mov D, reg — (D)«-(reg 57 50 51 52 55 54 55 56 JNC adder If CY-O,(PC)«-addr D2 al ah 
MOV E, reg (E)<(reg 5F 58 59 5А 5B 5C 5D 5E JC  addr* If CY-1,(PC)«—adár DA al ah 
MOV Н, reg H reg 67 60 61 62 63 64 65 66 JPO addr If P=0, (PC dar E2 al ah 
69 6A 6B 6C 6D 6E ТРЕ addrx If P=1, (PC)e-addr БА al ah 
MOV L, reg L reg 6F 68 69 6A 6B 6C а 1 ЕН 
MOV M, reg | (M)«-ireg) 77 70 71 72 15 74 15 — EM It 20 
JM addry If S=1, (PC FA al ah 
ACCUMULATOR GROUP PCHL X (PCh)=-(H), (2019-0) E9 
ADD reg А)—(А)+( теб » 87 80 81 82 83 84 85 86 CALL GROUP " 
ADC reg A)«-(A)*(reg)«(CY) + BF 88 89 8А 8B 8C 8D 8E CALL adar® TOS )«- (PC) , (PC )-adar CD al ah 
SUB reg A)-(A)- (reg, » 97 90 91 92 93 94 95 96 CNZ адаг If Z=0, (TOS )e-(PC), (PC )e-addr C4 al ah 
SBB reg A)--(A)-(reg)-(CY) * 9Р 98 98 9A 98 9C 9D 9E CZ addres If 2-1, (TOS)4-(PC),(PC)«-adàár CC al ah 
ARA reg A) A )A( reg, ж AT AO A1 A2 A3 АД А5 Аб CNC addry If CY=0, (TOS Ja BO addr D4 al ah 
XRA reg А) (А) reg, ж AF АВ A9 AA АВ AC AD AE CC  addr* If СҮ-1,(Т05)6-(РС de ddr no al ah 
ORA reg A)«-(A)V( reg » B7 BO Bi B2 B3 B4 BS Вб CPO addr* If P-O, (TOS)«-(PC),(PC)«-addr ЕД al ah 
боо ale + BA MER ECD BD C MA, DP. Моб (вајар add P4 al ah 
а -0, A а а. 
INC ECREMENT REGISTER CM addry If 5-1 quu addr FC al ah 
N.B. 90S )a- (PC) designates the following:- 
INR 1 04 ос 14 16 24 гс ( 
DOR Pe Бы (Вас е > 08 oD 15 1D a 2D 6 ((SP)-1)<-(PCy), ((SP)-2)—(PC1), (SP) —(sP)-2 
REGISTER мал GROUP m B D E SPPN E AN us 
RET PC)«-(TOS c9 
цөн rp = и о) H EH 2 = ENZ * If 2-0, 021) co 
rp 3B — ва * If 2-1, (ро) (тов) са 
LDAX te (5 ОА 1A -- -- x 
rp RNC If CY=0, (PC Jee (TOS) DO 
STAX rp 0212------ RO X If CY«1,(PC)-- (TOS) 18 
DAD rp E im нне 09 19 29 39 -- RPO X If P20, (PC)<-(TOS) EO 
PUSH rp X: Эв-(тв),((8Р)-2)46-(:1), C5 D5 E5 -- F5 RPE x If Pot, (PC (то) ES 
RP If 5-0, (PC)--(TOS FO 
POP rp* aa (zh)e-((SP)4+1), C1 D1 E1 — F1 * BM x m s1, PC Je (TOS) FB 
SP N.B. )--(TOS) designates the followings- 
DIRECT GROUP Е (PCh)<—((SP)+1),(SP)—(SP)+2 
LDA ‘addr _ (А)«-(адаг ЗА al ah RESTART AOE 
STA addr адаг) -(А 32 al ah RSTO Y 105) ын РС)4-016 ст 
LHLD addr L)«-(addr) ,(H}e-(adàr+1 ФА al ah RST 1 1 TOS PC), (РС 16 СЕ 
SHLD addr addr )«-(L) , (addr+ 1)9-(H 22 al ah RaT 5 у 105 PC), pe 106 D7 
16 DF 
IMMEDIATE GROUP кэт 4 x TOS (вс : ЫН ЕТ 
MVI A, data (A)«-data 3E dd , 16 ЕР 
MVI B, data (Bj«-data 06 ad RST 6 у TOS je (РС, 2016 F7 
7 x RST 7 TOS )a- (РС 38 
MVI C, data (С)ч-аала OE ad * , 16 ҮР 
MVI D, data (D)«-data 16 ad ROTATE/CONTROL/SPECIAL GROUP 
MVI E, data (E)«-datà 1E dd RLC n A A су А *** 
MVI H, data (H)«-data 26 ва RRC inet у: үе nu и; Т) тт ae 
МҮІ L, data (Lje-data 2E ва RAL 11 mere orje 21) e 17 
MVI M, data (M)«-data 36 dà RAR e dA ит M ар, „(cr (A0) *** 1F 
ADI data A A)+data » C6 да NOP „ No operation 00 
ACI data A)w-(A)+data+(CY) + СЕ да HLT у Processor stopped until interrupt ог reset 16 
SUI data A)«-(A)-data * D6 да DI Interrupts disabled F3 
SBI data А A)-data-(CY) + DE dd EI Interrupts enabled after next instruction FB 
ANT data А)я—(А)лдала. * E6 dd ns (55-31) و‎ E3 
XRI data A}w-(A)¥data * EE да h „(БР F9 
ORI data А)н-(А)удала * F6 dà XCHG нэ (0),(1)-н48) ЕВ 
-CPI data A)-data * FE àà DAA Decimal adjust accumulator * 27 
LXI B, addr (B)«-ah,(C)«-al 01 al ah ae ока ын d 
LXI D, addr (D з (Еје-а1 11 al ah смс үс е» 18 i 
LXI Н, addr, (Hje=ah, (L)emal 21 al ah 
: х 007 port | Not used in DCE Systems D3 port 
LXI SP,addr  (SPy)«-ah,(SPj al 51 al ah IN port DB port 
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| Micro equivalent of. starin 
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Since I’ve just purchased a musical high- 
resolution graphics computer -- the 
DAI — it seems appropriate to take a 
close look at how Гуе tackled a music 
playing program, While I'm at it, T 
throw in a few comments: about the 
DAI, then 1 move on to produce the 
into the 
flames of a fire, To finish off the article 
this month, Т suggest a competition 
which you may like to enter | 


Prelude and chance 


Bach's Prelude No. 1 from the 48 
Preludes and. Fugues is one of the few 
keyboard pieces that І can play ade- 





quately, the reason being that only one 
note is played at a time, except for the 
final chord. Figure 1 shows the first Баг, 
The next 32 hars of the piece each 
follow the same pattern: an ascending 
arpeggio of five notes, with. the last. 
ihres notes repeated; and then the 
whole sequence of eight notes repeated, 

here are then two hars each with. а 
slightly different pattern of pitches, 
without the exact repetition, And then 
the Prelude ends with a chord of notes 
played together, . | 

Such simplicity and regularity make 
it a natural piece to synthesise on my 
new computer, a DAI from Data 


"Applications, it has a sound chip, with 


three oscillators which are driven by 
Basic statements, 1 am not going to des- 
cribe all these facilities, but I'll give you 
just enough to follow the program I 
have written to realise the Prelude: 
Program A. Each note is shaned by an 
envelope, which gives it ar attack, sus. 
tain and decay portion, The shape of 
the envelope can determine the quality 
of the note as we perceive it just as 
much as the tone quality, or wave-form, 
of the sound. s 
ENVELOPE а e die fig hii 1 
ENVELOPE 1 8,4:15,8:10,20:0 

In this example: a is the envelope 
number, 0 or 1; с e and g are 
amplitudes, from 0 to 15; d f and h are 
durations, in arbitrary units of time of 
3.2 milliseconds; i is also an amplitude, 
and since it does not have a duration the 
note stays at this level indefinitely, 
until either another note is started on 
the same oscillator or the SOUND OFF 
statement is obeyed, There can he any 
number of amplitude duration pairs, 
The envelope: іп the second example is 
shown in Figure 2, 

Amplitude 0 is not silence but gives 
a positive audible level. A note cannot 
therefore be turned off simply by put- 


а 
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ting the final amplitude to zero. One ot 
the two aforementioned means must be 
used. This is inconvenient because the 
time that elapses in the program must 
be matched to the length of note 
required. rather than just leaving it. to 
the envelope to give a note of the right 
length, This is done most easily by using 
the WAIT TIME statement with a suit- 
able integer, which gives a delay in units 
of 20 milliseconds, Alternatively, the 
next bit of useful program can be 
obeyed, but this must he timed -> by 
trial and error — so that the note сан 
be ended at the right moment. 

ENVELOPE is a deelarative state. 
ment and obeying it does not cause any 
output. Two envelopes сал be stored at 
any one time and either of them can be 
redefined at any point in the program. 

A note is played by executing a 
SOUND statement: - маг : 
SOUNDabhede - | 
SOUND 2 115 0 4000, 
a is the number of the oscillator to be 
used, 0 1 or 2; b is the number of the 
envelope, 0 or 1: c is the overall 
amplitude for the note, 0 to 15; d is the 
tremolo or glissando, not used in this 
piece; e is the period of oscillation of 
the note in units. of 1⁄4 microseconds. 
in the example, 4000 units of !^ micro- 
second each gives я frequency of 500 
cycles per second, Because this is not a 
convenient way of specifying frequency, 
A huilt.in function is provided to do the 
conversion, Middle :C. happens to be a 
frequency of 256 cycles per second and 
FREQ(256) gives the number of units 
to achieve this frequency. i 

: In the program; a table is set up in 
PH(72) with the frequencies for six 
octaves of notes, in-order to save calling 
FREQ for each note as it is played. 


Sound quality 
The ‘sound produced by the oscillators 


із а simple square. wave, A note made 














wiih.a single oscillator is flat and unin- 
teresting. Being used to using sound 
synthesisers, it is the weediness of the 
notes that I find least appealing about 
most of the tune-plaving that is done on 
small computers, even when several 
notes are being played at once, In this 
program, since only one note is played 


. ata time, I use all three oscillators for 
‚ each note, They are coupled together in 


octaves in this case and, together with 


` the envelope, this gives a reasonably 


keyboard-like sound, It is obviously 
equally easy to set up other harmonic 
structures, including fifths and thirds 
above ite fundamental note, .. .. 
- It'is one ot the mysteries of percep- 
tion that we hear some such sounds as a 
single noie, while some other very 
similaz sounds are beard as chords of 
separate notes, Even the same sound can 
be heard in both ways, depending on 
whether the enmponent sounds ай 
start at the same time or come in one 
hy one, . | 
Even these notes seem somewhat 
dull and the ear quickly tires of the 
quality, Since the DAI has stereo sound 
output, as well as putting the sound 
out to the TV with the video signai, ! 
can conneci.this output to my small 
EMS synthesiser. This is essentially 
à collection of analogue devices, so that 
filtering snd a Кое bit ot reverberation 
can be added. The two halves of. the 
sound signal can also be ring-modulated 
together, which adds further to the 
harmonic spectrum of each note, A ring 
moculator takes two input frequencies, 
A and B, and ouputs their sum and 
difference, A+B and А-В. | 
» On the DAI oscillators 0 and 1 go 
to stereo channel 1, while oscillators 1 
and 2 go to channel. 2. In this piece, 
with the oscillators tuned in octaves, 
for each base frequency F, one channel 
has F and 2F while the other has 2F and 
4F. Thus the ring-modulator adds 3F - 
F-2F = 4F—F, БЕ = F+4F and GF = 
2F-4F, as well as repeating the frequen- 
cies already present, | 
`+ Although this involves a bit of arith- 
metic, it does take us outside the sub- 
ject of personal computing, since syn- 
thesisers are now far less common than 
computers, However I mention it 
because I believe that this approach of 
mixed analogue and digital synthesis 
is usually the most economical way of 
making electronic sounds, Each method 
has its own strengths: digital for 
completely. reliable; frequencies aad 
analogue for processes like reverbera- 
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| tion that are difficult to perform 
digitally. 


| Another unsatisfactory aspect of the: 


sound form this program is the rigid 
timing, which the ear quickly tires of. 
There are two approaches to this, both 
of which depend of altering the рата: 
meter to the WAIT TIME statements, 


since these are what determine the ` 


lengths of the individual notes. The 
refinements to the timing tend to be of 
two kinds: changes to single notes, 
usually for emphasis, and changes to 
whole phrases or sections. In the first 
approach, an extra piece of даа is 
added for each note to give its indivi- 
dual timing. in this way, both kinds of 
change can be made, but it is tedious 
to have to give another data item for 
every note. It also has the disadvantage 
of being awkward to change. Obviously 
‘this can be partly sclved hy using varia- 
bles rather than fixed data, For 
example, the first note of each of each 
bar should be emphasised. This can be 
| done by increasing the amplitude 
alightly, bul as important is to lengthen 
the nate by a tiny amount. Also, on the 
whole, lower notes are played more 
| slowly than higher ones, In this piece, 
| these two aspects work together since 
the first note in each bar ‘s also the 
lowest. 

The WAIT TIME statement is a litile 
crude for this kind of adjustment аз ¿he 
unit of time is 1/50 of a second. Алт 
such wait statement can be replaced by 
a duminy FOR loop: 

FOR L=1 TO M:NEXT L. 

By setting M, the time delay can be set 
in units that should be less than a milli- 
second — unless you have a very slow 
computer, M can then be set either 
from a data item, or using a formula 
based on pitch and position in the bar. 
The other approach is to contro} M 


paddle, This is most suitabie for the 
macro-changes and is equivalent to the 
function of a conductor, There is no 
reason why M cannot. be derived as a 
combination of a value from within the 
‘program and another one from the per. 
former, 


Program details 

Naw let me make a few comments on 
the program as it appears, which should 
help in following it and in adapting it 
to another system. 

In DAI's the distinction is made 
between integer variables and floating 
point ones, as it is in Fortran, This is in 
addition to, the usual further data type 
for string variables. The default option 
is that all variables are floating point. 
The IMPLICIT. statement aliows, for 
example, all those variables beginning 
І to Р to be declared as integer variables. 
This has to be done before any of the 
program is input as variables are given 
their type at the time the program line 
is input, IMPLICIT is therefore better 








program statement... … .. ° 

It is also. necessary to allocate space 
for arrays at the start of a program using 
the CLEAR statement. 

A peculiarity of the DAT system is 
that subscripts, even though they may 
be typed in as integers, are always listed 
— and presumably stored — as floating 
point numbers, This does not seem sen- 
sible, but I have not found a way round 

it yet. The program here 15 shown as it 
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with an input device such as а рате 


thought of as a command rather than a 
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was input 

An octave divdeu into 12 
equal semitones Since frequency is 
logarithmic -- double the frequency 
increases the pitch by аг octave — 
multiplying a frequency by the twelfth 
foot of 2 increases the pitch ћу a semi- 
tone, The frequency of ihe lowest note 
in the piece, C two cefaves below 
middle C, в 64, and this is зе: ћу Q. 
The whole niece can be “ranspesed up 


is 


or down in pitch by alterirg this inpia 














й = д 
б. | 
ху 
deca] J 
22 


| 
| 
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value for Q. To avoid smali errors creep. 
ing in from repeated multiplication it 
is better to compute just one octave of 
semitones and derive the others from it 
by doubling the frequencies. 

For the main part of the piece only 
five data items are needed for each bar 
and the program expands these. The 
notes are numbered from the lowest as 
1, while middle C, for exampie is 25. | 
These numbers, which are easier [0] 
transcribe from the score than the; 
actual frequencies, are conyerted to the | 
appropriate frequency values via the: 
table PH. | 

The iast two bers need eight values ! 
fcr each half bar. The same subroutine | 
is used to play each group of eight | 
potes. A problem arises from the fact, 
that for each group of notes it takes a | 
perceptibie period of time to get the, 
data for the next group and start the | 
loop again. So it is necessary to have z | 
slightly shorter WAIT after the last note. i 
of each group than after cach сі the | 
otaers. І found thai three units less was | 
the right amount, ! 

. In the statements, I expected that | 
the two higher components would need 
somewhat lower amplitudes than the — 
fundamental, but on схрегипепќайоп 

I found that having them all at the | 
maximum level of 15 gave as good a 
result. as апу. 

A characteristic of natural sounds is 
fhat the higher frequencies both start | 
and die away more quickly. 1 have! 
modelled this very roughly by using à | 
slightly shorter envelope for the two 
higher components in each note. А gain, 
this is a matter for experimentation. Át 
one point i had the envelopes numbered 
the wrong way round and I did notice | 
that the effect was slightly dulled com- 
pared to the intended way, and a tiny 
bit less like the harpsichord sound J was ; 
after. Not that the final result is at all | 
like a real instrument — it is clearly | 

| 














synthetic, but has a pleasing little twang 
te it. 

The final chord is nut satisfactory. 
The notes are spread a little in time | 
and are heard as a chord, but since there 
is only one oscillator per note, the 
effect is feeble, when it should rather- 
end the piece with 2 good solid sound 

This Prelude is the one taken by | 
Gounod as the accompaniment tor His 
‘Ave Maris’, a piece of Victorian kitsch 
that | cannot take seriously, but ту! 
next project is to take the top oscillator | 
out and use it for tne Gounod tune io 
see if something listenable can be made 
of it. 


DAI comments 


I am in the process of learning the реси. 
lierities of my new DAI system. 1 chase 

it particuarly for the high resolution |. 
colou» graphics and am very well: 
plevsed with il. But some idiosy nctacies 1 
of its Basic are worth recording. On the i 
detit side the problem with floating | 
point subscripts has already been men. | 
tioned, The most glaring amission is the 
absence of user defined functions Very 
odd. On the plus side І particularly i 
like the MOD operator, I 7 MOD ° 
puts T equal to 1, the remainder of 7 
on division by 3. This can always be 
defined as a user function in a system | 
that allows them, in the following way: | 
DEF FNM(LN) = 1--N*INT(I/N). | 








But Е profer to have it as an operator 
rather than a function as this is „ere 
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like the standard mathematical data must be within the program: none to: Patterns Competition, Personal 

notation. can be input at run time, The output Computer World, 14 Rathbone Place, 
In my next article, I will write about can be in any form on paper, graphics London WiP 1DE. 

applying the MOD operator to the or text produced directly by the compu- The result and the winning entry 

Fibonacci series and similar sequences ter system. Unlike the program just will be published in the December issue 

of numbers as an economical way of given above, this one must terminate of PCW. I'm sure the editor wouldn't 

generating patterns, ‘after a finite time, not run on indefini- mind Jing a year's free subscription 
Another small bonus on the DAI is tely. to PCW (agreed — Ed). ў 

the extended RND function, RND(N) Send your entry by 30 August 1981 | 

for М = 0 returns a random value in the 













range 0 to 1 generated by hardware, for А | • 
М < 0 it starts a new, repeatable, (9 IMPAR INTIR Implicit integer variables 
sequence of software generated values, - 100 DIM NT(8 Pitch codes in eee • 
ын di Ң x : | qu : tt пре x 120 DIM PH(? 0 5,4.10,6;15,8;10,10;5,20;0 Бене ~ = 
Y 1 . . 319,8:10,10| ој 
range 0 to М from the software genera | 180 VELOPE 1 5,2;10,4;15,6:10,8;8,0;0 — Envelope for upper notes | ® 
tor. 91140 848Ц1/18) Factor for semiton 
While this last facility only savesone | | 150 "64 | Base note, Low C ^ e 
multiply ш; scale a value, over the [e 160 FTOR 1е1 ТО 13 For each мээн 
: : : ня | tink 
НО RND function, I find it neat and 180 FOR J=0 TO 60 STEP 12 For each octave о • 
` e 199 m (I)-FREQ(M*Q) Stora frequency үе 
зар oublie M: an ос e 
More patterns e| 210 NEXT Мех! осте tp [е 
220 $ 98 Increase by a semitone 
So let me end with some different 290 EXT 1 Next semitone • 
random patterns, Ф 803 DATA 25:20.82,87,41 | Data for bars 1 to 83 
my own зудын this ogee [ы DATA oen : 
on my own system, this program has ,29,82,37,4 
been run on the Tektronix system at 310 ВАТА 25,29,8 41,46 • 
Systems Simulation Ltd, as have ай the | e 312 DATA 25, 32 30 | 
graphics programs for my previous 814 DATA 24,25,29,82, e 
articles, 1 am greateful to John e| 316 DATA 22,25,29,32,37 1 
Lansdown for his generosity in allow- 318 БАТА 15,22,27, 2 ^4 
ing me this access, It was also John who e| 322 АТА 20,23,29 32 38 
first proposed the uem in tiles that 324 DATA 18,22,27,34, 
I wrote about the May and June issues 32 DATA 18,21,27,80,8 9 
of PCW. Being an architect, he framed |®| 328 DATA 1520253257 
it in terms of a set of rooms with 832 АТА 156 18 29 25! e | 
connecting doors, none or one in each [Ф] 334 DATA 8,15,30 3 
wall, to form a single connected apart- 286 DATA 18,17,20,26,29 e 
ment. This was six or seven years ago | @} 340 D АБА 6 18 292 39 
and I had quite forgotten their origin 342 DATA 7:13:22:25,28 e 
а І оше across my set of шэн e 814 DATA 8,18,24,25,28 
earlier this year and began to write | / э18,24,25,27. • 
about them. Indeed, І thought I must | ө 359 DATA 2102026 ag 
have invented the problem myself. 352 DATA 8,15,20:25,30 e 
" John also те a series іп the BCS |e 484 DATA 210202600 
omputer Bulletin on computers and э 02229, 
the arts which is always fascinating to e 358 DATA НЕ 9 
А 9 Ф + + 
read. He is the only person who has 362 DATA 8,15,20,24,30 
пои mor шив 0 He Computer аси. DATA 118:18:23:38:80,26.22 Data for bars 34 to 85 í 
Arts Society than I have over the years | 368 DATA 26.22.18 29.18.15 18 15 а | 
since we started it in 1968. 370 DATA 1 12.32 36.38.42 39.36 @ 
Опе ot the first things that many | | ® 872 DATA 38,36 ,82,86,27,80,20,27 En 
Ї Ї = or e 
fandom walk or dranken dot pattern [е] 40 FOR ICI ТО For tach nola Я 
It only takes a few lines of code: see 430 NEXT I Next note e 
Program B. The patterns in Figure 3 [е] 440 NT(6)-NT(3 Copy last 3 notes 
have each been produced by this 158 NT 1 ZNE i : • 
program, using different values of M. |®| 470 GOSUB 800 Subroutines to play 8 notes 
Now that coal fires are so rare, these 474 WAIT TIME 1 Slight puse for emphasis | ф 
ictures are the electronic substitute | g | 480 GOSUB 800 Barne 8 notes again 
or staring into. As well as the obvious 680 ТИ ТО4 еа БАРЫ 4 
snail trail, people see maps, faces, crea- |e| 510 FOR 1-1 TO 8 For each note — 
ше, mineral structures, vegetation "e 832 READ МТО) Read 8 notes e 
perhaps whatever is on their mind, The . ext note 
equivalent program running on my DAI, [9] 540 NRSUR 800 Subroutine to play 8 notes |. 
with coloured celis on the screen, pro- e| 552 ENVELOPE 0 5,6:10,8:15,20:10,20:5,20:0 Envelope for last chord • 
duced a very authentic map of southern 560 SOUND 00 15 ОРН(18) 18 note of chord 
Africa for a friend of mine just back 892 BOUND 015 0 PH(20) Slight delay e 
from there, with the tribal homelands |®| 572 . VT TIME 5 Delay 
and Malawi picked out. Such is random- 680 SOUND 2 0 15 0 PH(29) Srd note 9 
ness, 5 890 SOUND 00 15 0 PH(37) te note 
You will notice that there is also an мүн e 
effect from the bluntness of the pen [е 600 DAIT SINE 50 Hold for Бүсээ” 
! T 610 SOUND OFF Turn off the aoun А 
vee It : о! possible to show the plot 100 MR. Uto End of piece lay 8 notes | ® 
or M = 0,2 because the pen worked so [а - ubroutine to play 8 no 
` 810 SOUND 0 0 15 0 PH(NT(K Base fre 
Intensely in one area that it wore a hole 820 SOUND11150 HINT a) locaveup ^ e 
n the paper! | e| 830 SOUND 2 1 15 0 РН(МТ(К)-24 2 octaves u 
Competition UE SON шиши |e 
о e no 
©] 860 NEXT К Next note 
A small prize will be given for the most HUM VAIT te 1 Вам d time ton leat К. 
interesting output from an original short |®| 590 ND 


program in Basic. The conditions are 
that the program be less than ten Ines 


with only one statement per line, All 407 
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micro-electronica т bedrijf 


De snelle ontwikkeling van moderne | betalingen mogelijk geworden door 


technische hulpmiddelen komt als 
een golf over ons heen. Dit uit zich 
onder meer in de opkomst van de 
micro-electronica, die zo ongeveer 
samenvalt met de ontwikkeling van 
een industrieel beleid, dat is gericht 
op vernieuwing (innovatie). De 
echte doorbraak kwam pas bij de 
introductie van geintegreerde 
schakelingen. Sindsdien heeft de 
ontwikkeling van de 'chip' zich in 
een sneltreinvaart voortgezet. In de 
loop der jaren is met name het 
formaat van de computer enorm 
afgenomen. Mede door de lage prijs 
еп de hoge werksneiheid wordt 
micro-electronica steeds vaker 
toegepast. Zo is bijvoorbeeld een 
snelle verwerking van de stroom 


ver-doorgevoerde automatisering 
bij banken. Micro-electronica is 
echter niet alleen een hulpmiddel 
voor het verrichten van rekenwerk. 
Micro-electronische schakelingen 
zijn op de meest onverwachte 
plaatsen te vinden, ook in het 
dagelijks leven. Denkt u maar aan 
polshorloges, televisietoestellen en 
foto-apparatuur, om maar eens 
enkele voorbeeiden te noemen. 
Micro-electronica biedt veel 
mogelijkheden, 66k voor uw bedrijf. 
Door het gebruik van micro- 
computers kan de kwaliteit van uw | 
produkt(en) duidelijk worden 
verbeterd. 

In de cursus Micro-electronica in 
bedrijf leert u welke mogelijkheden 





er zijn om deze techniek toe te 
passen bij úw specifieke 
produkt(en). Het gaat daarbij om de 
innovatie in het produkt, maar óók 
in het produktieproces. 
Micro-electronica in bedrijf, wellicht 
uw bedrijf? 

Inhoud 
De cursus is bedoeld voor het 
hoger- en middenkader van 
industrieën en bedrijven. Mensen 
die beslissingen nemen over het wel 
of niet innoveren in een 
werksituatie. 

‘Micro-electronica in bedrijf’ 
handelt over de toepassing van 
micro-electronica bij de 
verandering en verbetering van 
produkten en produktieprocessen. 
Er wordt aandacht besteed aan de 











micro-electronica in bedrijf 








technische mogelijkheden van 
micro-electronische componenten, 
het belang van deze techniek voor 
het Nederlandse bedrijfsleven en de 
diverse bedrijfskundige aspecten 
van een innovatieproces in het 
algemeen. De cursus geeft, populair 
gezegd, de nodige bedrijfskundige 
kennis voor technici en de nodige 
technische kennis voor de meer 
bedrijfskundig geïnteresseerden. 
Voor alle duidelijkheid: de cursus 
‘Micro-electronica in bedrijf’ is géén 
vervolg cp de cursussen ‘Micro- 
processors’ die Teleac eerder 
verzorgde. 

In ‘Micro-electronica in bedrijf’ 
worden zowel de technische, als de 
sociaal/economische aspecten 
uitvoerig behandeld. Voorai het 
laatstgenoemde aspect verdient de 
аапдаст, omdat toepassing van 
micro-eiectronica in een bedrijf 
пода! wat veranderingen vereist. 
Veranderingen van de 
bedriifsstructuur, maar ook een 
wijziging in de 
arbeidsomstandigheden en het 
takenpakket van de werknemers. 
Zo is een numeriek bestuurde 
draaibank een goed voorbeeld van 
een machine, die zelf reeksen 
handelingen uitvoert. Deze 
handelingen moest de bankwerker 
vroeger zelf verrichten. Nu worden 
de handelingen vooraf ingesteld en 
daarna zal de machine zonder 
tussenkomst van de mens ze keer 
op keer reproduceren met groot 
gemak, grote nauwkeurigheid en 
grote snelheid. Door de introductie 
van de micro-electronica is er in dit 
voorbeeld voor de bankwerker, die 
vroeger routinematig 
werkzaamheden verrichtte, weinig 
plaats meer. De machine kan zijn 
werk sneller en vaak nauwkeuriger 
uitvoeren. Er zal echter een nieuw 
vak ontstaan, namelijk het beroep 
om werktekeningen om te zetten in 
een reeks opeenvolgende 
handelingen voor de machine. De 
man die deze werkzaamheden 
verricht, zal inzicht moeten hebben 
in de mogelijke basishandelingen 
van de machine. 

Hoe kunnen al deze veranderingen 
worden opgevangen? Moeten de 
arbeiders worden omgeschoold of 
is het beter om mankracht in te 
huren om een computerprogramma 





te maken? Zo ja, welke mensen zijn 
daarvoor dan nodig? 

Dit zijn slechts enkele van de vele 
vragen die in de cursus worden 
beantwoord. Een groot deel van de 
onderwerpen zal worden behandeld 
aan de hand van 
praktijkvoorbeelden uit 
Nederlandse bedrijven. 


Huiswerk ____ 


Tijdens voorgaande cursussen van 


Teleac is gebleken, dat er bij de 
cursisten behoefte bestaat om de 
kennis te toetsen aan de hand van 
huiswerkopgaven. De enige manier 
om het ingeleverde huiswerk juist 
еп ѕпеі te kunnen nakijken, is via 
het systeem van multiple choice- 
vraagstukken. Bij de cursus ‘Micro- 
electronica in bedrijf’ horen 
wekelijks diagnostische 
meerkeuzevragen. Bij de correctie 
van de vraagstukken wordt u er op 
gewezen welk gedeelte van de stof 
u verkeerd begrepen heeft en nog 
eens na moet kijken. 

Het is voor uw studie van wezenlijk 
belang dat u regelmatig uw 
huiswerk ter correctie inzendt. Het 
huiswerk wordt met behulp van een 
computer gecorrigeerd en uw 
resultaten ontvangt u vervolgens 
schriftelijk binnen een week nadat u 
het materiaal heeft ingestuurd. 

Het is niet mogelijk de cursus met 
een examen af te sluiten. Wel krijgt 
iedereen die in voldoende mate 
heeft deelgenomen aan de 
huiscorrectie, ter afsluiting een 
verklaring van deelname. Op deze 
verklaring wordt het aantal lessen 
vermeld waarvan huiswerk is 
ontvangen, evenals de behaalde 
gemiddelde score. 


Studievoorwaarden 

De Stichting Teleac, afdeling 
schriftelijk onderwijs is erkend door 
de minister van Onderwijs en 
Wetenschappen bij beschikking van 
1 juni 1978, kenmerk vo/ov/sro- 
502.368. 

Als zodanig is Teleac bevoegd 
huiswerkcorrectie te verzorgen. Bij 
de cursussen waarbij 
huiswerkcorrectie aan het 
cursuspakket is toegevoegd — in dit 
geval de cursus ‘Micro-electronica 
in bedrijf’ — zijn de 
studievoorwaarden van Teleac van 








toepassing. Deze 
studievoorwaarden kunt u vinden 
op pagina 10 van dit 
cursusprogramma. 


Televisie 
De serie bestaat uit twintig 
televisielessen van dertig minuten. 
De uitzendingen vinden piaats op 
dinsdagavond van 18.28-18.58 uur 
via Nederland 1; de herhalingen op 
zaterdagmorgen van 10.50-11.20 
uur via Nederland 1. De eerste 
uitzending is op 3 november 1981. 





Radio 
Naast de televisielessen zullen ook 
twintig radioprogramma's van 
dertig minuten worden verzorgd. In 
de radiolessen zal vooral worden 
ingegaan op de mens in het 
automatiserings- en 
innovatieproces. 

De radio-uitzendingen vinden plaats 
op donderdag van 21.30-22.00 uur 
op Hilversum 2; de herhalingen op 
zaterdag van 21.30-22.00 uur op ` 
Hilversum 2. De eerste uitzending is 
op 15 oktober 1981. In de eerste drie 
programma’s zal worden 
gediscussieerd over de 
maatschappelijke gevolgen van de 
invoering van micro-electronica. 





Cursuspakket 
Het cursuspakket bestaat uit de 
volgende onderdelen: 

— twintig televisielessen van dertig 
minuten; 

~ twintig radiolessen van dertig 
minuten; 

— een losbladig cursusboek van 
ruim 400 bladzijden; 

— wekelijkse huiswerkcorrectie; 

~ uitgebreide documentatie. 
Extra: 

— een slotmanifestatie in het 
voorjaar van 1982. 





Cursusprijs 
De prijs voor dit pakket bedraagt 

f 275,—/BF 4165, inclusief 
huiswerkcorrectie, BTw en 
verzendkosten. U kunt cursist 
worden door f 275 — over te maken 
op postgirc 544232 ten name van 
Teleac, Utrecht, onder vermelding 
van: Micrs-electronica in bedrijf. 
Voor Beigische cursisten geldt een 
andere hestelwijze. Zie hiervoor 
pagina 27. 
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ЯСЕНЬ SPEECH SYNTHESISERS 3 їйХ5Ж800 04: 3104: 53:3433ї 


In de vele iicrocomputerti jdschriften zijn de laatste tijd heelwat 

artikels verschenen betreffende speech synthesisers.. 

док in de advertenties vait op dat het aanbad van kleine заары 

spraaksystemen voor de meeste populaire micros ( APPLE, TRS-80, РЕТ, enz.) 

enorm is toegencmen. 

Verschillend grote firma's brengen nu spraak-IC’s uit. 

Om er maar enkele te vernoemen: TI, NS, GI, УОТБАХ, ..... 

Om te beginnen moet er een duidelijk onderscheid gemaakt 

worden tussen de verschillende scorten spraaksystemen. 

(1) Fixed vocabulary is een eerste soort. | 
Hierbij bevindt een ( beperkte ) woordenschat zich op een of | 
andere manier in ROM gecodeerd еп wordt vervolgens teruguitgelezen 
en gedecodeerd. Na wat filtreren enz. is apnieuw een verstaanbaar 
taal te horen. Meestal wordt vertrokken van hoge kwaliteits 
bandopnamen die in professionele studio’s worden gedigitaliseerd. 
Texas Instrument, National Semiconductor en General Instruments 
brengen dergelijke systemen op de markt. Ze zijn in hoofdzaak 
bestemd voor "dedicated applications" bvb. een ROM kan 
"ingesproken worden met woorden die typisch zijn voor een N 
wagen. De woordenschat гїегуал zou totaal verschillend zijn 
van die van een winkelkassa. 

Het interessante is echter dat deze firma’s evaluation kits 
verkopen met een algemeen bruikbare woordenschat. 

(2) Het tweede soort kan geen volledige woorden maar wel fonemen 
ten gehore brengen. Groot voordeel hierbij is dat men niet 
beperkt blijft tot een vaste woordenschat. Het nadeel is dat het 
uitspreken van een woord iets meer moeite kost. 

Meestal zijn deze systemen ook duurder. 

Toonaangevend op dit vlak is de firma VOTRAX. Onlangs 
heeft deze de 50-01 op de markt gebracht voor ongeveer 
$70. Deze prijs omvat ailen de chip. Een volledig systeem 
kost $375 (TYPE-’N-TALK). 

Na deze korte inieiding kunnen we even kiiken naar de artikels die 

onlangs verschenen engewi jd waren aan “spraak voor computers’ 

(1) Micro Systemes Mars-Avril 1981 р.97-109 
Presenteert een zelfbouwproject met een 1802 processor. 

Het systeem kan zowel met de hand als door de P.C. bestuurd 

worden. Misschien heeft een DAInamicer reeds zo een systeem gebouwd 

Graag zau ik weten hoe het klinkt. 

Het is gebaseerd op het tweede systeem, fonetisch dus. 

Nadeel is wel dat de fonetiek van de verschillende talen niet 
„gelijk zijn! In het Engels of het Frans vinded we klanken 

die het Nederlands niet kent еп omgekeerd. 

(2) BYTE June 1981 p.44-48 > 
Eveneens van zelfbouw project volledig gebaseerd op de 
SPC DIGITALKER van M.S..Dit systeem heeft een woordenschat 
bestaande uit een zinnetje (this is diaitalker) en 143 
algeeeen bruikbare woorden (cijfers, eenheden, enz.) дэн 

(3) KILOBAUD MICROCOMPUTING May 1981 р.154-159 
Зак hier wordt een zelfbouw project met de SPC beschreven 

Buiten nr. (1) weinig origineei. De schema's zijn bijna letterlijk 

Overgenomen uit de datasheets van М.З. 

Ook op de Dhi-dag ee ee dhr. SIP een dergelijk systeem 

aangesioten op de DCE bus. 

Ikzelf denk sr aan om een dergelidk systeem te commercialiseren 

maar dan wel met enige extratjes zoals volumeregeling enz. 

Wie geïnteresseerd is kan contact opnemen met DAInamic. 

Om naar uit te kijken s in BYTE van September moet een 

systeem gebaseerd op de 5С-01 verschijnen! 
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MICRO,DO YOU HEAR ME ? 





a voice recognition sytem 


Tus advertisement announced BIG EARS in bold capital let- 
ters making me wonder if this was a joke from Toy Town; 
however, a quick scan of the text showed that this was another 
product from William Stuart Systems. As I already own an 
audio oscilloscope and a colour graphics system from the same 
stable I feit confident that my £45 -- VAT was not going to buy 
a toy. I confess to being somewhat relieved that when I un- 
packed my parcel less than a week later the name Big Ears was 
not on the brushed aluminium front but in its place an im- 
pressive “Speech Recognition System Interface SR 1." 

Big Ears or SR1 can be connected to any personal computer 
like NASCOM, TRS 80, PET, UK101, Superboard or to any 
other ма a spare user input port. In my case, an 8K UK 101, 
hooking up couldn't have been much simpler with just five con- 
nections to be made. Five core ribbon cable and standard 5 pin 
DIN plug are provided so plugging in the SR! is quite 
straightforward. Power requirements are low so the +5 volts 
needed comes from the motherboard via the ribbon cable. All 
this is explained in a very clear User Manual containing Connec- 
tion Details, Software Loading Instructions, User Instructions, 
Demonstration Software, Theory of Operation and BASIC 
Software Listings. A small part of the software is written in 
machine code and is provided in a form to suit the most popular 
6502 or Z80 based systems. 

The purpose of the SRI, if you hadn't guessed, is to provide 
speech input to your computer and open the door to direct man- 
machine communication. For anyone who has formed a close 
interpersonal love affair with their computer (yes Ursula Katrina 
101 is a person) then giving her Big Ears could well extend a 
beautiful relationship. To be more exact it is more like one Big 
Ear in that her ear comes in the form of an electret condenser 
microphone plugged into the smart aluminium facia of a black 
metal case 15cm x 12cm x 5ст using a standard jack plug. 
Relationships can blossom in that with a speech recognition 
system it’s conceivable that one’s computer could be verbally 
commanded to execute various options in robot control, games 
programs, etc. Captain Kirk could command “Fire” to zap the 
Klingons or a remote controlled vehicle could be requested to 
move “Forward”, “Back”, “Left” or “Right”. It is even con- 
ceivable that I could flirt with Ursula Katrina via an interac- 
tional conversation program in which she would only have lear- 
ned (and thus understood) my voiceprint; such faithfulness! 

The minimum amount of memory required by the SR1 is 5K 
but since machine code real-time input routines are loaded into 
the top of user memory the last one K must be located in the 8th 


K sockets leaving the 5th, 6th and 7th sockets empty in the UK 
101/Superboard. However, now that 2114 Rams aren't so ex- 
pensive one might as well upgrade to 8K unless funds are very 
tight. 8K will allow a larger vocabulary to be stored. 

The demonstration software (BASIC) is very interesting 
providing correlation tables for the words learnt anda 5 х 6 
two-dimensional array of numbers as the individual word’s 
*voiceprint". During the learning stage the computer asks for 
the word to be spelled and then spoken. The spoken word should 
be repeated 4 to 8 times to achieve optimum recognition and the 
voiceprint is printed each time. It is naturally important to speak 
clearly and consistently. Having taught the computer a number 
of words it is then possible to test its recognition. It can have 
problems understanding the difference between Fine, Pine and 
Wine but less problems distinguishing between Apples, Pears 
and Raspberries. The computer compares the voice it hears with 
its averaged memory voiceprints and perceives you to have said 
the word which has the highest correlation. It signals its un- 
derstanding by printing "You said Raspberries" or whatever. 
Both the correfation table and voiceprint printout can be deleted 
by removing lines and the computer's response can be tailored to 
individual needs. 

The computer's voice perception is based on frequency 


analysis ‘of the first and second formants of the speech — 


waveform. The interface unit SR! separates the formants anc 
delivers digital values to the computer which then performs fre- 
quency analysis for each of sixty-four 16ms sampling periods. 
This is implemented in machine code. For each period the two 
formant counts are then compared against threshold data values 
to determine which frequency ranges are present. The two range 
indices are then used to determine which location in a two- , 
dimensional array will be incremented. Thus the sixty-four 16ms 
samples must all fit in this two-dimensional histogram forming a 
kind of “frequency-space”. To learn a word four or more such 
histograms are averaged and normalised to have a mean value 
of zero with a uniform standard deviation. The resulting 
averaged voiceprint-histogram is stored for future correlation. 

If necessary the sensitivity of the SR1 can be adjusted by go- 
ing inside the cabinet with a small screwdriver and adjusting a 
preset potentiometer; clockwise to increase and anti-clockwise 
to decrease. The systems software is listening for the first sound 
in order to start sampling but if the system is too sensitive it 
could be triggered by background noise. In noisy environments 
this adjustment is very useful as sensitivity can be set low and 
the speaker can speak up. Don’t clear your voice or stutter 
because Ursula (or whoever) will be less than understanding 


about it. Moreover one should remember that with sixty-four — 


samples of 16ms any phrase or word to be learnt should not las 
longer than about one second. This is quite okay in practice as 
long as one avoids Welsh railway station names. 

If one wishes to use the SR1 in the application of data enquiry 
(which might need a large vocabulary) then the secret of success 
is to use key words to define which group of words the computer 
can expect you to be using next. In this way the computer need 
only compare the word it hears with a reasonably small group of 
words and the chance of misunderstandings is thus correspon- 
dingly reduced. Words which the computer might confuse can 
be located in different groups. Vocabulary, therefore, can grow 
like a tree. An example of this is a Travel Reservation System 
which might initially ask “Inland, European or Intercontinen- 
tal?” Each of these headings might access 8 or 10 destinations 
with further destinations to be found by “Other” always being 
one of the options. 

In conclusion Ursula Katrina’s Big Ear might not be quite as 
perceptive as a human ear but then it’s not such fun to nibble 
either. Notwithstanding that I’m still convinced that she’s got the 
hot-heatsinks for me... “Love me Katrina?”... “І DO 
HONEY”... If only things could always be that easy. 


Practical Electronics September 1981 


TYPE-N-TALK IS ТАТ 
The exciting text-to-speech synthesizer 


that has every computer і 


* Unlimited vocabulary 

° Built-in text-to-speech 
algorithm 

* 70 to 100 bits-per-second 
speech synihosizer 


Type-'N-Talk/" an important technological 
advance from Votrax, enables your com- 
puter to talk to you simply and clearly — 
with an unlimited vocabulary. You can 
enjoy the many features of Type-'N-Talk,™ 
the new text-to-speech synthesizer, for 
just $345.00. 

You operate Type-'N-Talk" by simply typ- 
ing English text and a talk command. 
Your typewritten words are automatically 
translated into electronic speech by the 
system's microprocessor-based text-to- 
speech algorithm. 


The endless uses of 

speech synthesis. 

Type-'N-Talk “adds a whole new world of 
speaking roles to your computer. You can 
program verbal reminders to prompt you 
through a complex routine and make your 
computer announce events. In teaching, 
the computer with Type-'N-Talk "can 
actually tell students when they're right 
Or wrong — even praise a correct answer. 
And of course, Type-'N-Talk "is great fun 
for computer games. Your games come to 
life with spoken threats of danger, re- 
minders, and praise. Now all computers 
can speak. Make yours one of the first. 


Text-to-syeech is easy. 

English text is automatically translated 
into electronically synthesized speech 
with Type-'N-Talk:” ASCII code from 
your computer's keyboard is fed to 
Type-'N-Talk “through an RS 232C inter- 
face to generate synthesized speech. 


Just enter English text and hear the verbal 


response (electronic speech) through your 
audio loud speaker. For example: simply 
type the ASCII characters representing 
"h-e-1-1-o" to generate the spoken 

word "hello." 


TYPE-'N-TALK "has its 
own memory. 

Type-'N-Talk “has its own built-in micro- 
processor and a 750 character buffer-to hold 
the words you've typed. Even the smallest 
computer can execute programs and speak 
simultaneously. Type-'N-Talk "doesn't have 
to use your host computer's memory, or tie it 
up with time-consuming text translation. 


Data switching capability 
allows for ONLINE usage. 


Place Type-'N-Talk" between a computer 
or modem and a terminal. Type-'N-Talk " 
can speak all data sent to the terminal 
while online with a computer. Information 
randomly accessed from a data base can 
be verbalized. Using the Type-'N-Talk " 
data switching capability, the unit can be 
"de-selected" while data is sent to the ter- 
minal and vice-versa — permitting speech 
and visual data to be independently sent 
on a single data channel. 


Selectable features make 
interfacing versatile. 
Type-'N-Talk "can be interfaced in several 
ways using special control characters. 
Connect it directly to a computer's serial 
interface. Then a terminal, line printer, or 
additional Type-'N-Talk "units can be ` 
connected to the first Type-'N-Talk;" 
eliminating the need for additional 
RS-232C ports on your computer. 

Using unit assignment codes, multiple 
Type-'N-Talk "units can be daisy-chained. | 
Unit addressing codes allow independent 
control of Type-'N-Talk'"units and 

your printer. 


Look what you get for $345.00. 
TYPE-'N-TALK comes with: 


* Text-to-speech algorithm 

* A one-watt audio amplifier 

* SC-01 speech synthesizer chip (data 
rate: 70 to 100 bits per second) 

* 750 character buffer 

* Data switching capability 

* Selectable data modes for versatile 
interfacing 

* Baud rate (75-9600) 

* Data echo of ASCII characters 

* Phoneme access modes 

* RS 232C interface 

* Complete programming and installation 
instructions 

The Votrax Type-'N-Talk" is one of the 

easiest-to-program speech synthesizers on 

the market. It uses the least amount of 

memory and it gives you the most flexibie 

vocabulary available anywhere. 


Order now. Toll free. 
nnn ининин um ни ү 


Call the toll-free number below іо Щ 
|| order or request additional infor- 
mation. MasterCard or Visa 

a accepted. Charge to your credit 
|| card ог send а check for $345.00 
a 
a 
|| 


plus $4.00 delivery. Add 4% sales 
tax in Michigan. D 


1-800-521-1350. 


Joa 


Distributed by Vodex 
A Votrex Company — Dept. RT 
500 Stephenson Highway, Troy, MI 48084 


(313) 588-0341 


Type-'N- Talk vis covered by a limited warranty. 
Write Votrax for а free copy. 


197 


H. Baumann 


n 
i 
' 


dialoog met machine geen toekomstmuziek meer 


Ook in gewone huis, tuin- en 
keukenzaken heeft de “chip” al 
lang zijn intrede gedaan. Het is 
ondertussen al min of meer 
gewoon geworden dat bij 
winkelkassa”s, wasautomaten en 
naaimachines, instrukties via 

een toetsenbordje worden 
doorgegeven en dat een of andere 
vorm van microprocessor ervoor 
zorgt dat de machine die wensen 
stipt uitvoert. 

Maar een wasmachine zonder 
knoppen die mondelinge 
instrukties uitvoert, of 
bijvoorbeeld een automatisch 
lasapparaat dat met de technicus 
een babbeltje maakt over een 
werkstuk, dat is weer even iets 
anders. Voor sommigen een 
wensdroom, voor anderen een 
schrikbeeld, maar door vrijwel 
iedereen voorlopig nog als science- 
fiction beschouwd. Toch is het dat 
al lang niet meer. Er wordt op het 
ogenblik heel hard gewerkt om 
machines te leren praten en 
luisteren. 
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Volgens ingewijden duurt het niet tanger 
meer dan pakweg een jaar of twee, voor- 
dat we de eerste schrijfmachine hebben 
waarbij het toetsenbord is vervangen 
door een mikrofoon. Voorleesapparaten 
voor blinden en spreek- en leesappara- 
tuur voor doofstommen zullen ook niet 
lang meer op zich laten wachten. 

Een van de experts op dit gebied be- 
weerde onlangs al schertsend dat het 
hoog · tijd werd om maatregelen te 
nemen die het gebruik van spre- 
kende instrumenten in vliegtuigcock- 
pit verbieden — daarbij wijzend op de 
akoestische chaos die ontstaat als 20 
20 meetinstrumenten door elkaar gaan 
zitten praten, 


Dat mag dan een tikje overdreven zijn, 
feit is wel dat men met de sprekende 
machines al veel verder op scheut is dan 
de meesten erg in hebben. Alle reden 
dus om eens nader op deze materie in 
te gaan. . 

Omwille van de overzichtelijkheid is dit 
artikel opgesplitst in twee delen; in het 
eerste deel zullen we ons hoofdzakelijk 
bezig houden met het kunstmatig op- 
wekken van spraaksignalen, terwijl in 
het tweede deel aandacht wordt besteed 
aan de problematiek rond het "gehoor" 
van de machines 


De eerste pogingen 

Twee elementaire bestanddelen van 
spraakachtige klanken vindt men terug 
in de zg. mondtrommel; een instrument 
dat in de volksmuziek van het alpenge- 
bied graag gebruikt wordt. Zo'n 


mondtrommel bestaat uit een blikken 





Figuur 1, Het eerste elektronische apparaat 
waarmee stemgeluiden konden worden 
opgewekt werd in 1936 gebouwd door 

K. W. Wagner. Ondanks de simpele opzet 
waren de prestaties al verrassend goed te 
noemen. 

——— کے 


spraaksyntese 


tong (de generator), opgehangen in een 
metalen houder. Terwijl hij op die 
tong tokkelt, drukt de speler de houder 
tegen zijn tanden en gebruikt dan zijn 
mondholte als klankkast. Door de 
mondopening groter en kleiner te ma- 
ken, verandert de kleur van het gepro- 
duceerde geluid. Geoefende spelers 
kunnen zo klanken voortbrengen die 
sterk doen denken aan de klinkers 
а, е, i, o en u in verschillende toonhoog- 
ten, zulks afhankelijk van de afmetingen 
van hun “klankkast”. ү 

Reeds in 1936 ontwierp ene meneer 
K.W. Wagner een systeem waarmee het 
akoestische — generator/klankkast-prin- 
cipe welhaast perfekt langs elektrische 


0) 


weg kan worden gerealiseerd. Figuur 1 
toont dat het daarbij ging om een im- 
puls-generator, gevolgd door een aantal 
resonantiefilters ("formant-filters''). 
Met dit, naar hedendaagse begrippen 
gerekend zeer simpele apparaat konden 
alle klinkers, alsmede de stemhebbende 
medeklinkers |, m, n en r reeds zo goed 
worden gesyntetiseerd, dat zelfs indivi- 
duele kleuring van het geluid mogelijk 
was. 

Slechts luttele jaren later kwam 
H. Dudley in.de Bell Telephone Labora- 
tories een belangrijke stap verder: 
voortbordurend op Wagners vinding, 
bouwde hij in 1939 de "voder" (voice 
operation demonstrator). Dit spraak- 
apparaat was al in staat om alie klanken 
op te wekken die voor normale spraak 
nodig zijn —al hing het resultaat wel 
voor een groot deel af van de bekwaam- 
heid van -degene die de knoppen 
bediende. іп de opzet van de "модег“ 
zijn al zoveel spraakgenerator-principes 
te herkennen dat een nadere beschou- 
wing zeker de moeite waard is. Maar 
eerst even een kort uitstapje naar 46 
PTT. 

Wanneer u per telefoon naar de juiste 
tijd informeert, dan hoort u aan de 
andere kant van de lijn de stem van een 
beklagenswaardig iemand die ooit eens 
een bandje met tijden voor een hele 
dag ingesproken moet hebben. Een 
monnikenwerk! In werkelijkheid loopt 
het echter zo’n vaart niet: elk getal, 
alsmede de woorden “uur”, “mi- 
nuut(en)", "en", "sekonde(n)" zijn 
slechts één enkele keer opgenomen 
en.elke afzonderlijke tijdsaankondiging 
wordt automatisch uit deze woorden 
samengesteld. 

We gaan in gedachten eens een stapje 
verder en beperken de ontleding van een 
zin niet tot de afzonderlijke woorden, 
maar bekijken ook de klanken waaruit 


spraaksyntese 





elk gesproken woord is samengesteld. 
Het woord "acht" bijvoorbeeld, bestaat 
uit drie spraakklanken (“fonemen”): de 
klinker "а", de op rose ruis gelijkende 
"ch'' en de harde klank "t"', Deze klan- 
ken vormen de kleinst mogelijke ele- 
menten waarin spraak valt te ontleden. 
Wanneer het lukt om alle voor een 
bepaalde taal noodzakelijke klanken op 
te wekken, dan is het mogelijk om een 
machine te laten ‘praten’, En dat is 
nu precies wat Dudley's ‘‘voder” ai 
kon. 

Figuur 2 geeft het blokschema van het 
door Dudley ontwikkelde apparaat. Een 
impulsgenerator die een signaal produ- 
ceert dat rijk is aan harmonischen, levert 
het ruwe materiaal voor alle stemheb- 
‘bende klanken, een ruisgenerator doet 
dienst als signaalbron voor de stemloze 
klanken (zoals bijv. de f, s, sch, enz). 
Welke klank er gevormd wordt, hangt 
voor een zeer groot deel af van de instel- 
ling van de filterbank die^ achter де 
generators is geschakeld en die het 
karakteristieke spektrum  (formantbe- 
reik) van elke klank nabootst. Een 
voorbeeld: de klank "s" maakt de 
inschakeling noodzakelijk van een filter 
dat op een vrij hoge frekwentie is 
afgestemd, terwijl de "sch" een stuk 
donkerder klinkt waardoor het filter 
dus een veel lagere doorlaatfrekwentie 
zal moeten hebben. 

Verschillende filterschakelaars van de 
voder zijn onderling gekoppeld, zodat 
„ег tegelijkertijd meerdere formant- 
bereiken іп de signaalweg kunnen 
worden geschakeld. Met een extra 
schakelaar (“zacht”) kan de geluids- 
sterkte bij stemloze klanken worden 
verminderd. Tenslotte zijn er nog drie 
schakelaars voor fonomen die echt een 
luchtdrukstoot veroorzaken (de zoge- 
heten plofklanken): d, b en de Duitse g 
in de stand "stemhebbend" en t, pen k 
in de stand "stemloos" van de omscha- 
kelaar. Om geen steriel robotgeluid te 
krijgen, moet — net als dat bij normale 
‘spraak gebeurt — bovendien onder het 
spreken de toonhooge van "de impuls- 
generator worden gevarieerd, Daarom is 
voorzien in een toonhoogte-pedaal. 

Al met al een behoorlijk gekompliceerd 
apparaat, dat een haast artistieke be- 
kwaamheid vergde van de "'knoppenist" 
(zie figuur 3). Vervangt men echter 
de "live'"-bediening door een geschikte 
automatische sturing van de afzonder- 
lijke funkties (bijv. m.b.v. een pons- 
band), dan is de eigenlijke “spreek- 
machine" perfekt. Aan de principiële 
opbouw ervan is (tenminste bij de 
foneem-generators) sinds Dudley’s voder 
praktisch niets veranderd. De afme- 
tingen zijn intussen echter tot het 
formaat van een Eurokaartje gekrom- 
pen — recentelijk zelfs tot het formaat 
van een IC, 


Nieuwe oplossingen 

Alle tot dusver bekende metoden om 
tot spraaksyntese te komen, vallen in 
twee kategorieën onder te brengen: 
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ruis- 

generator stemhebbend/stemloos 
UD 

impuls- 


Figuur 2. Blokschema van de “voder” 






„ Dit in 1939 door Homer Dudley ontworpen apparaat 


kan worden beschouwd als de eerste echte "spreekmaschine"', Alle voorkomende spraakklanken 
konden er natuurgetrouw mee worden nagebootst. 





spraakopwekkers die komplete woor- 
den in een geheugen opslaan (woord- 
generators) en typen die alle afzonder- 
lijke зргааККапКей kunnen vormen en 
daaruit willekeurige woorden samen- 
stellen (foneemgenerators). Omdat de 
werking van de eerstgenoemde groep 
wat eenvoudiger is, zuilen we die maar 
het eerst onder de loep nemen. 


Woordgenerators 

De mogelijkheid om hele woorden in 
halfgeleidergeheugens (ROM's) ор te 
slaan kon pas serieus worden overwogen 
toen de geheugenkapaciteit hiervan 
belangrijk toenam en tegelijk de prijs 
lager werd. Dit type generator vraagt 
namelijk nogal wat geheugenruimte. 
Alle woorden worden in hun totaliteit 
gedigitaliseerd, en. in het geheugen 
gestopt, waarna ze elk onder een apart 
adres kunnen worden afgeroepen. Dat 
maakt het mogelijk om op zeer een- 
voudige wijze zinnen te vormen: men 
hoeft slechts de woordadressen па 
elkaar af te vragen om een komplete 
zin te krijgen. Deze vorm van program- 
mering kan door elke gebruiker zelf 
worden uitgevoerd en vereist geen 
bijzonderde spraakteoretische kennis, 


. daar aan het spraakmateriaal zelf niets 


wordt veranderd. 

Het zou echter een zeer onekonomische 
aangelegenheid zijn om het spraak- 
signaal simpelweg met een A/D-omzet- 
ter te digitaliseren en dan de bits in 
ROM's of RAM's op te slaan. Al naar 
gelang de resolutie van de A/D-omzetter 
in kwestie krijgt men zo namelijk een 
hoeveelheid informatie van 50.000 tot 
100.000 bits voor elke sekonde dat het 
spraaksignaal duurt. Het is derhalve zaak 
om deze hoeveelheid zoveel mogelijk 
te reduceren, alvorens die in een geheu- 
gen op te slaan. Dat is ook heel goed 
mogelijk, aangezien onze spraak veel 
meer elementen bevat dan voor een 
goede verstaanbaarheid strikt nood- 
zakelijk is. 


Zonder merkbare verslechtering van de 
herkenbaarheid kan een aanzienlijk deel 
van die in wezen overtollige informatie 
gewoon worden weggelaten. Dat dit zo 
is kan iedereen gemakkelijk zelf nagaan; 
zelfs wanneer men luid schreeuwt 
(zonder verfijnde artikulatie dus), met 
volle mond praat of bij ontzettend veel 
achtergrondlawaai (fabriekshal, waterval, 
slechte tetefoonverbinding), dan nog. 
blijft de verstaanbaarheid meestal ver- 
rassend goed. Informatie-reduktie kan 
op verschillende manieren worden 
bereikt: 

a. Adaptieve deltamodulatie 

Aangezien spraak, als gevolg van de 
mechanische traagheid van de mense- 
lijke spraakorganen, slechts relatief lang- 
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zame amplitudevariaties bevat, is het 
onnodig om voor ieder digitaliserings- Да 
punt opnieuw de absolute amplitude: 
in het geheugen op te slaan; het volstaan 


om de amplitudeverandering  tussen ae | | у 
twee opeenvolgende punten vast te . гл Minutes and Hours p 
leggen. | хил 7 


Aangenomen dat een bepaald punt een 
amplitudewaarde van 500 bezit, dan 
hoeft men echt niet te verwachten dat 
er onmiddelijk daarna een sprong naar 
bijv. 18 zal optreden. Daar de digitali- 
sering plaatsvindt met een frekwentie 
die tenminste twee maal zo hoog is als 
de hoogste spraakfrekwentie, zijn de 
tussenpozen waarmee het ingangssignaal 
gemonsterd wordt zd kort dat het 
verschil tussen twee opeenvolgende ат- 
plitudenwaarden nooit groter dan + of 
-25 zal zijn, De volgende waarde zal 
dus ongetwijfeld ergens tussen 475 en 
525 liggen. Het opslaan van dat verschil 
in het geheugen kost aanzienlijk minder 
bits dan het steeds opnieuw vastleggen 
van de absolute amplitudewaarde. 

Met een klein beetje moeite kan nog 
meer aan geheugenruimte worden be- 
spaard; wanneer we de amplitude steeds 
een zelfde (gemiddeld) stapje groter of 
kleiner laten worden, dan kan bij elk 
digitaliseringspunt worden volstaan met Figuur 4a. Het IC UAA1003 van ITT is een 1-chip-spraakgenerator. Behalve de eigenlijke 

een  richtingsaanduiding: “omhoog” spraakgenerator bevat het ook een geprogrammeerd geheugen (ROM) met een kapaciteit van 
(logisch 1) of “omlaag” (logisch 0). maximaal 20 woorden. Uitbreiding van het geheugen is niet mogelijk en het IC leent zich dus bij 


Deltamodulatie geeft dus al een behoor. “МК voor korte aankondigingen. 
lijke besparing aan geheugenruimte. 
b. Onderdrukking van signaalkompo- 4b ` 
nenten met geringe amplitude 
Frekwenties die па Fourier-analyse 
slechts met een zeer kleine amplitude 
in het spraaksignaal vertegenwoordigd 
blijken, kunnen nagenoeg zonder enig 
kwaliteitsverlies worden weggelaten. 
De totale hoeveelheid vast te leggen 
informatie kan daarmee tot ongeveer 
de helft worden teruggebracht. 

c. Herhaling van pseudostatische tril- 
lingsperioden 

Dat klinkt een beetje moeilijk, maar dat 
is het niet. Het betreft hier een vorm 
van kompressie die gebaseerd is op het 
feit dat afzonderlijke trillingen binnen 
een bepaalde stemloze of stemhebbende 
klank onderling geen markante verschil- 
len vertonen. Een langgerekte klinker 
bijvoorbeeld, hoeft daarom niet perse 
in zijn geheel te worden vastgelegd; het 
volstaat om één periode te bekijken en 
die samen met een herhalingsinstruktie 
(voor een bepaald aantal perioden) in 
het geheugen op te slaan. Meestal is 
herhaling met een faktor 4 mogelijk bij 
stemhebbende en een faktor 10 bij 
stemloze klanken. Ook dit geeft een 


aanzienlijke besparing aan benodigde | . 
h : Figuur 4b. Typische toepassing van de ЏАА1003-1 in een “sprekende” digitale klok. 
ge eugenruimte. m 
De data-ingangen van de spraakgenerator zijn rechtstreeks met de anoden van de 7-segment 
Tot nu toe wordt de toepassing van displays van de klok verbonden. Via de “alarm”-uitgang van het klok-IC wordt een tijdsaankon- 
kunstmatige spraakapparatuur volgens diging verkregen met wektoon vooraf; drukknop “start 2" is voor tijdsaankondigingen zonder 
het woordgenerator-principe toch nog wektoon. De instelpot bepaalt de interne clock-frekwentie van de UAA1003; de aan pen 34 
steeds beperkt door enkele wezenlijke т levert een referentiestroom welke het nivo van het uitgangssignaal op 
nadelen. : ina vi ; : 
В н Я 57 : In rust trekt de schakeling via реп 17 en 19 een uiterst geringe “stand by"-stroom. Aan het 
1. De vokabulaire i5 koa Won pro- begin van elke aankondiging wordt via pen 12 de aan pen 20 liggende transistor opengestuurd; 
gramma" uit , te breiden. Wellswaar die levert dan de voor de aankondiging benodigde stroom. Het gemiddelde stroomverbruik blijft 
Киппеп. де ROM's tegenwoordig al door zo heel laag. р : 
de fabrikant van een specifieke voka- Tussen het generator-IC en de LF-versterker kan met een simpel bandfilter worden volstaan. 
| bulaire worden voorzien als men dat 
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Figuur б. De spraakmodule VSM 2032 ven General Instruments i uingevoerd ais een kien 
steekprintje en bevat een komplete spraaksynthesizer. bestaande uit interface-unit, sprask- 
generator-IC 5Р-0250, ROM en LF-verstarker. Пе adressering geschiedt via een 
microprocessoraysteem met 8 ТТ. котра ћеје adressignaion (zie Sb), Er kunnen 

128 woorden worden geadresseerd: de kapaciteit bedraagt ongeveer 30 веков еп spraak. 
Behalve ROM's met standaardinhoud, levert 5,1. ook narr wens geprogrammeerde КЄМ» 





— en 


wete > 
wenst, maar voor wijzigingen of uitbrei: 
dingen is gelijk een heel nieuwe ROM 
nodig. Wil het voor de gebruikers nog 
een beetje goedkoop en ekonomisch 
blijven, dan zullen zij zich dus moeten 
beperken tct het gebruik van standaard- 
vokabulaires; het feit dat ietwat afwij- 
kende eisen het apparaat al gauw 
letterlijk ea figuurlijk sprakeloos doen 
staan moet mer dan maar op de koop 
toe nemen, 
2. De totale woordenschat van woord- 
generators is, hoe dan ook, zeer 
beperkt; het haalbare maximum ligt op 
het ogenblik bij ongeveer 250 woorden. 
Bij dit aantal heeft de “Speech 
Processor Set" van National Semi- 
conductor al 128 Kbit aan geheugen- 
ruimte nodig en dat is zelfs naar hui- 
dige begrippen gerekend niet bepaald 
weinig. Daar komt nog bij dat deze 
verhouding tussen vokabulaire еп цас 
heugenruimte slechts mogelijk is als 
alle mogelijke infor matie-reduktietruuks 
worden toegepast — anders zou er aan- 
zienlijk meer geheugenruimte nodig zijn 
geweest. 
3. Onze spraak. is eigenlijk zeer gekom- 
pliceerd van samenstelling: het gaat 
niet allee: om de juiste afzonderlijke 
klanken, maar er zijn ook nog tal van 
overgangen, klemtoonvariaties, pauzes 
en toonhoogtewisselingen. Deze para- 
meters liggen bovendien niet vast, maar 
veranderen voor elk woord al naar 
gelang de kontext waarin het wordt 
gebruikt. Zo leren kinderen bijvoorbeeld 
al углед om aan het eind van cen zin de 
toonhoogte van hun stem te laten 
dalen. Dat is nu precies een van die 
dingen die een woordgenerator niet 
kan: elk woord is met een neutrale 
uitspraak in het ROM vastgelegd, zodat 
de geproduceerde spraak altijd sterk 
aan robotstemmen zal doen denken 
en geen echt menselijk karakter 
heeft. . 
Dat wil overigens niet zeggen dat e 
voor de woordgenerator totaal geen toe- 
komstperspektief zou zijn — tensictte 
zijn we andertussen ook gewend geraakt 
aan de ја ке, maar praktische zeven- 
segment-symbolen. 


Forsetrganerstors 

Deze groep spraakapparatuur vertoont 
sterke verwantschap met  Dudlay's 
"voder"-koncepx. Ook hier vinden we 
de eigenlijke spraakgensrator met stem- 
hebbend/stemioos klankopwekkers, als- 
. mede de formantfilters en de toon- 
hoogtesturing. Nieuw ten opzichte van 
de vader zijn echter де geheugencellen 
waarin de werkvoorschriften (aigorit- 
men) zijn opgeslagen voor de vorming 
van de afzonderlijke fonemen. : 
Wanneer er aan de ingang van het 


‚ Spraakbiok een instruktie метоба? 


tot vorming van een bepaaide Ф#спгега, 
dan worden aile parameters zó ingesteld 
dat het generatorsignaal in kombinatie 
met de tilterwerking het juiste geluid 
oplevert. Af naar gelang de komplexiteit 
van de te produceren klanken, kunnen 
daarvoor maximaal 10 parameters 
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tegelijk nodig zijn. Voor de vorming van 
een  standaardvokubulaire heeft de 
foneemgenerator dus nog een geheugen 
nodig waarin de foneemkodes worden 
opgesiagen van de voor elk woord 
benodigde afzonderlijke klanken. 

Het grote voordeel van foneemsyntese 
zal ondertussen duidelijk zijn. Als het 
apparaat in staat is om alle klanken weer 


te geven die in een taalfamilie voor- 


komen, dan beschikt het in principe 
over de komplete woordenschat van 
deze talen. Weliswaar bezit elke taal 
meer klanken dan letters, maar aange- 
zien dat aantal in ieder geval onder de 
honderd blijft, zijn ze toch betrekkelijk 
gemakkelijk zonder een buitensporige 
hoeveelheid foneem-vormingskodes te 
reproduceren. Voor de taalgroep Duits/ 
Engels bijvoorbeeld, volstaan 64 
fonemen om alle voorkomende woorden 
goed verstaanbaar te syntetiseren. 

De organisatie van elk foneemkomman- 
do geschiedt bij de VOTRAX VS-6.0 
(от maar een voorbeeld te noemen) т 
de vorm van een 8-bit kodewoord. Van 
die 8 bit dienen er 6 voor het uitkiezen 


1 van de gewenste foneem en worden er 


twee gebruikt om met behulp van toon- 
hoogtevariaties etc. de spraak levendiger 
en echter te doen schijnen. In de 64 
foneemkodes zijn ook verschillende 
variatie-stapjes inbegrepen voor klem- 
toon en snelheid van een bepaalde 
klank, zodat er sprake is van een over- 
zichtelijke en duidelijke samenhang 
tussen kode en klank. Tabel 1 toont 
als voorbeeld de foneeminstrukties 
van de  VOTRAXSCO! speech 
synthesizer. 

Net zo goed als de vormingsparameters 
van geluid tot geluid verschillen, is ook 
de lengte van elke komplete foneem 
weer anders. Die kan variëren van 
250 ms voor de langste, tot 47 ms voor 
de kortste klank. Pauze-instrukties en 
een "stop'-kode kompleteren het in- 
struktiepakket. 


In plaats van bij een paar (meestal drie 
of vier) formantfilters in een bepaalde 
volgorde de resonantiefrekwentie te 
veranderen, zoals dat bij de VOTRAX 
gebeurt, kan men ook een stel (tot 
maximum 15) parallelgeschakelde filters 
toepassen die elk een andere vast-inge- 
stelde resonantiefrekwentie bezitten. 

Als ingangssignaal dient weer het stem- 
hebbend/stemloos signaal van de 
impuls-, respektievelijk ruisgenerator. 
Variaties in het klankkarakter worden 


‘bereikt door elk afzonderlijk filter 
te laten volgen door een spannings-- 


gestuurde versterker (VCA); daarmee 
kan het aandeel dat elk gefilterd fre- 
kwentiebandje in het uiteindelijke ge- 
luidsspektrum heeft worden vastgelegd 
— precies zoals dat in het syntesedee! 


` van een vocoder gebeurt. 


Voor het vastleggen van de vormings- 
algoritmen wordt bij de fabrikant het 
amplitude-aandeel van elk afzonderlijk 
frekwentiebandje voor de fonemen 
onderzocht en in een geheugen opge- 
slagen. 
foneemsyntese met formantfilters vormt 


Een speciale variant van de. 


het Linear Predictive Coding (LPC). 
Evenals bij de vorige metode is ook 
hier de flexibiliteit van de geprodu- 
ceerde spraak zeer hoog en de vokabu- 
laire onbeperkt. 

Bij foneemgenerators kan ook gebruik 
worden gemaakt van alle eerderge- 
noemde (bij de bespreking van de 
woordgenerator) truuks om geheugen- 
ruimte te sparen. De winst die dat 
oplevert kan worden gebruikt voor de 
regeling van de zogeheten ."allofonen; 
dat zijn de zich tussen de afzonderlijke 
fonemen in bevindende overgangstoe- 
standen, welke in hoge mate mede- 
bepalend zijn voor de natuurlijkheid 
van de spraak, 


Samenvattend kan worden vastgesteld 


dat foneemgenerators voldoen aan zeer 


hoge eisen wat betreft woordenschat 
en uitspraak. Het enige maar’. vormt 


"eigenlijk het feit dat де vokabulaire niet 


in letters maar in klanken moet worden 
ontleed en geprogrammeerd. Schrijf-.en 
spreektaal liggen zo goed als altijd een 
flink eind uiteen (met het Fins als 
gunstige en bijvoorbeeld het Frans als 
bijzonder ongunstige uitzondering). Tot 
dusver was het daarom niet mogelijk 
om де vokabulaire van een spraaksyn- 
tesizer volgens het foneemgenerator- 
principe met behulp van een toetsen- 


„bordje іп te voeren. 


Recentelijk is men er echter in 
geslaagd om de "spreekmachines’ ook 
spraakregels bij te brengen; voor het 
Amerikaanse taalgebied bestaan al 
verschillende programma’s die de om- 
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Figuur 6. De SP-0256 van G.I. is een verdere ontwikkeling van de SP-0250. Deze nieuwe 
woordgenerator heeft een geheugen van 16K НОМ, Bovendien kan er maximaal 491K externe 
ROM worden geadresseerd. Opvallend is het programmeerbare digitale filter in de sprask- 
synthesizer. Bij de opzet van dat filter hebben de eigenschappen van de menselijke spraak- 
organen als voorbeeld gediend en het stelt de gebruiker in staat om zelf de kwaliteit en dus de 
vereiste киши voor de geproduceerde spraak (tussen са. 700 en 2000 bit per sekonde) 
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та 
Phoneme Phoneme Duration Example 
| Code Symbol (ms) Word 
| 00 ЕНЗ 59 jacket 
| DIGITALKER 01 EH2 71 enlist 
| | 02 ЕН1 121 heavy 
03 PAQ 47 no sound 
| 04 рт 47 butter 
05. А2 7! made 
1 06 А1 103 made 
47 ZH 90 azure 
08 АН2 7! honest 
69 13 55 inhibit 
ФА . 12 80 inhibit 
* Only required for clocked 08 l1 121 inhibit 
dynamic ROMS 0C м 103 01 
00 N 80 зт 
ФЕ B 71 bag 
OF V 71 van 
19 CH* 71 chip 
FILTER AND 11 SH 121 shop 
AMPLIFIER SPEAKER 12 2 71 200 
13 АМА 146 lawful 
= 14 NG 121 thing 
15 . . АНІ 146 father 
16 001 . 103 looking 
17 OO 185 book 
18 L 103 land 
19 K 80 trick_ 
1A J* : 47 judge | 
1B H 71 ‘hello 
ic G 71 get 
4 10 Е 103 fast 
| 1E D 55 рам _ 
| 2 А 85 баў 
1 day 
AOR 1-14 : ay 
SPC Roata 1-1 | DIGITALKER 21 ‚ АҮ ` 65 day 
ROWER KIT 22 Ү1 80 yard 
M | 23 UH3 47 "mission 
SPEECH OSC | 24 AH 250 mop 
25 P 103 past 
CRT а | 26 о 185 · cold 
27 I 185 pin 
: | 28 U 185 move 
* Only required for clocked ' А 29 Y 103 any 
dynamic ROMs 2A T 71 tap 
К ` 28 R 90 red 
2 2С Е 185 meet 
20 М 80 win 
° „Б. “Я 2E AE 185 dad 
= 23 2F АЕ1 103 after 
И 30 AW2 90 safty 
31 UH2 71 about 
32 он 103 uncle 
SPEECH (FROM SPC) 33 ын 185 CUR 
aur 200 „ғ 34 02 80 for 
+1|- 35 01 121 aboard 
Hy гт” 36 IU 59 you 
р 37 ил 90 you 
38 THV 80 the 
, 39 TH 71 thin 
200 Hz = ee 3A ER 146 bird 
* LM346 or equivalent “а 81140-7b 36 Эн "s Us 
| 3D AW 250 call 
й ЗЕ РА1 185 no sound 
Figuur 7. "Digitalker" noemt National Semiconductor haar spraaksyntese-systeem. Het Я ЗЕ 5ТОР 47 no sound. 
bestaat uit een spraakprocessor mat externe ROM's. Figuur 7a toont de allereenvoudigste 
toepassing met een "schakelaar-interface" voor de adreskeuze. De SPC (speech processor) haalt 
de bij het gekozen 8 bit adres behorende digitale informatie uit de ROM en zet die in spraak 
signalen om. Er kunnen 256 verschillende woorden resp. zinnen worden afgeroepen. De SPC 
kan 128 K-ROM rechtstreeks adresseran en eenvoudig met een nog groter geheugen worden ` 
uitgebreid. Figuur 7b toont nog een typische toepassing van hat IC in kombinatie met een Tabel 1. Foneeminstrukties van de 


up-Systeem en met een zo eenvoudig mogelijk gehouden LF-filtering. . VOTRAX SC 01 speech synthesizer. 
on SUMMAE LU ety eer TER ge eias s SL аа EEE rta EEN. 
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zetting verzorgen van letter-toetsenbord 
naar klank-kode. Als we de frabrikant 
mogen geloven, dan zullen dergelijke 
microprocessor-programma's binnenkort 
ook in andere talen beschikbaar zijn. 
De door de machines te spreken tekst 
kan dan zo vanaf het papieren koncept 
worden ingetikt, hetgeen vooral bij vaak 
mcx F--4 wisselende teksten (beursberichten, tele- 
I 07 foonbeantwoorder) een niet onaanzien- 

ЇЇК voordeel betekent. | 





Welk systeem wordt het? 
Over de vraag welk type spraaksyn- 





Latch (1) 
Phoneme 
Code 








Audio 5: Е 
Output tesizer de beste papieren heeft voor de 








Acknowledge/ š N ы 5 . 
Reque 4 toekomst, valt wellicht een voorzichtige 
төвөө 0 prognose te doen als we dé benodigde 





geheugenruimte (in bit per sekonde) van 
#114028: | ° de beide systemen eens op een rijtje 
| zetten: 


woordgenerators 

digitalisering met gedeeltelijke*informa- 
tiereduktie . . . ca. 2000 bps 
digitalisering met gebruikmaking var” 
alle mogelijke reduktiemetoden...ca. 
600-800 bps 

| foneemgenerators 

MES цав сан Ne ING linear predictive coding . . . са. 1200 bps 

| volgens systeem van de ”’уоЧег””. . . са. 

70 bps 

: | Dat laat aan duidelijkheid niets te меп- 

топит à . sen over. Wat de benodigde geheugen- 

Time s ruimte voor de spraakkodes betreft, 
Algorithm biedt de  "voder'-achtige foneem- 

ў generator grote voordelen. Toch zal, 

zeker als geheugenruimte nòg goedkoper 
gaat worden, ook het woordgenerator- 
systeem met vaste vokabulaires zich 
waarschijnlijk ook wel handhaven; voor- 
al bij toepassingen waar een vokabulaire 
van zo'n 500 woorden (wellicht haal- 
haar maximum) voldoende is en een 
zekere steriliteit van het geluid niet 
storend is, vormt de eenvoudige pro- 

` qrammering een ijzersterk punt. 





Literatuur: 

Pedro the Voder. A machine that talks. 
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The voder Electrician, Lond. 123 
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Rabiner, L.R. Computer Synthesis of 
Speech by Conatenation of Formant: 
Coded Words. Bell System Technical . 
Journal (1971) 


| | Mcllroy, M. Douglas. Synthetic English - 
Figuur 8. Het CMOC-IC 5С-01 van VOTRAX herbergt een vrijwel komplete foneemgenerator. Speech by Rule. Вей Telephone 


Figuur Ва toont де in- en uitgangen, M.b.v. 8 bit adressen (zie tabel 1) kunnen 64 verschillende Laboratories Inc, Murray Hill, NJ 
fonemen worden afgeroepen, Twee andere bits (pitch) maken een kauze tussen vier verschillen- Teja, E. Voice input and output. EDN. 





de toonhoogten mogelijk. Met “latch” wordt da laatst ingegeven foneemkode іп een November (1979) 
tussengeheugen opgeslagen. Als de geadresseerde foneem aan de uitgang is verschenen, vindt via Diverse publikaties van de volgende 
R/A een terugmelding plaats, waarmee de generator de volgende foneemkode opvraagt. firma’s: 


Van de drie audio-uitgangen levert er slechts dán het spraaksignaal, In figuur 8b is te zien dat 
AO de stuuruitgang is voor de (externe) eindtransistoren; AF dient voor de tegenkoppeling en Comp pid Consultants Box 1951 

CB voor de ruststroominstelling van de eindtrap. Sante Monica CA 90406 

Figuur Bb illustreert tavans de warking van de foneemgenerator, De foneemkode aan de ingang Telesensory Systems 3408 Hillview Ave 


belandt eerst bij een tussengeheugen an adresseert vervolgens een ROM waarin de foneem- Palo Alto CA 94304 
parameters zijn opgeslagen. Die ROM stuurt het syntese-deel, dat uit.een impulsgenerator voor Votrax Div of Federal Screw Works 
de stemhebbende klanken (voiced source), een ruisgenerator voor de stemloze klanken 500 Stephenson Hwy Troy MI 48084 
{fricative source) en vier foneemfilters (F1... F4) bestaat, Voor da stemhebbende klanken : ' ` 
wordt de toonhoogte van de generator rechtstraeks via а de i ingangen 11 en. 12 bepaald — dus ` National Semiconductor Corp 
onafhankelijk van da foneemkode, : | 2900 Semiconductor Dr 

| Santa Clara СА 95051 м 
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SCHR © Lieto IH HARDWARE 


Dat men by de DAI-FC PCHRECi Soa in moet tikken om het Tl-zscherm te 

clearen iz een tekortkomina in het ontwerp van de DAI, Hardwarematia is 
dit of te lossen met de volgende schakelins in CHüZ:die met еп druk or 
een ekstra toets het TU-zcherm netjes schoonveeat. Door uitbreidins van 
de zchakelina kan men elke gewenste funktie OF POCKET. 


m 
й 
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їр 


ekde naar de ofbouw van het DSI-PC keyboard Czie fia. 12. 

" dat het keyboard bedraad iz volaens de matrix die U 

m het НӨНРБОПК oF rFasina 34. 

are worden de horizontale lsnen vanuit de 5501 om de beurt 
waarbs de software telkens de vertikale lynen aja de 
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tz inzedrukt iz. Пе het moment dat rin 27 van 1233 

wordt Bin 3 van ICSE en dus oak Fin 35 van [СЭЗ роба. 

aH en S3 of het el-board zitten ziet men in fis. 42. 

n de kode die се dat beraalde moment aan de Finnen 33° tem 
anaeboden wordt bepaalt de software welke toets er inae- 
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лс» ў П om B . 


m й gig 


шейт 22 

Ban de kesboard-zchakelaarz kan men andere schakelaars Parallel aanzlui- 
ten waardoor de werking van het keyboard niet beinvloed wordt. Hiervan 
wordt by deze schakelina aebruik aemaakt. 


In fis. 2 wordt de funktie FUH? met één schakelaar aerealizeerd. 

In de rusttoestand iz de flip-flop (401329 serezet. Fin Г iz hooa › waar- 

door de JOHHSOH-teller (40179 ook sereset sehauden wordt. UF de clock 

insana Fin 145» van de 4017 staan de rFulzen van [БЕЗ rin 11, die resel- 
ч 


matis door de software ba het scannen 2 het k 
den. Ге uitsansen van de analose schakelaars Cd 
keuboard-switchez Е. Ш.Н end verbonden, |. 
Drukt men or de schakelaar RUH; dan wordt de flir-flor seset. dus rin 
15 van de 4017 wordt laas en de 4817 kan saan tellen. 


board агаве 
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је 

eerd wore 
162 zan Farallsl 


met de. 


— dU 
T 


Ва de eerztuolsende puls or rin 14 wordt Fin 2 hoos en de eerste analaose 
zchakelaar wordt зегјоћеп, De zaftuare ziet dit via de 5581 en er wer 
zchgnt een E ор het Tl-zcherm. Es de wolaende euls or Fin 14 wordt Fin 2 
laas en Fin 4 hoca. De volsende analose schakelaar wordt aesloten zodat 
er een `L oF het scherm verschynt enzovoorts. TEN 
Ale Fin 1 hoos wordt, wordt de 4015 зегезе en de 4017 weer ssblakkeerd. 


Een uitbreidina van deze schakelina ziet men in fia. 3, Waarin de funkties 
РОНЕ 1232, Ra, LIST en EDIT zun sersealizeerd. Моск wat betreft de 
nummerins in het schema een voorbeeldie: Fin 3 wan ICZ18 САНГ» заах naar 
Fin Z van ЇС215 CORD en naar Pin 5 van IC 284 СӨН8 08 SWITCH. 


HADELEN: 19 Es het aanzetten van de РС beaint de teller soms te loren ёр 
men kryat dan een SYNTAX ERROR. | 
23 In verhoudina veel hardware nodis Сусс’ de zchakelina van 
fis. $ al 17 IC's !^. Mil men поз meer funkties realiseren 
dan wordt het interessant om een FROM te aebruiken. 
39 Het keyboard moet іп: UPPER CASE mode staan. 


De schakelins heb ik via een flat-cable aanaezloten. Het beste kan men 
de draden woorzichtis op de achterzyde van het FC board се de Finnen wan 
ICES en 98 еп or de Pinnen van het blauwe weerstandenblokie rechts naast 
IC98 solderen. | 
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DAT PERSONAL COMPUTER 999 DAI PERSONAL COMPUTER °°°DAI PERSONAL 
0 zwart alle adressen in HEXvorm! 
1 blauu — nne 
2 d.rood 
d OD 29B-29C start heap 131,0 output ѕсгп+ 
ie ана 290-29Е size heap RS232 
аа 29F -2A0 start text buffer 131,1 screen only 
Б - Бе 241-242 start symbol table 131.2 edit buffer 
2 I Brun 2А3-2А4 end of symbol table 1552 read from 
8 A AT 245-246 bottom screen ram edit buffer 
gri js 
9 blauw 
E 75 cursor symbol MODE  XMAX ҮМАХ 
12056 74 cursor mode 
Te Dy bana 72-13 cursor position 1/2 a Ва 
13 Iogrgen 3⁄4 159 129 
14 geel 5/6 335 255 
15 uit 40,28 cass motor 1 DN 
40,18 cass motor 2 ON MERGE 
40,30 1 and 2 OFF OCLEAR XXX 
01 OAD "AT 
”7 COLORG BY R2 R3 RA CEDIT BREAK/BREAK 
20 21 22 23 °LOAD"B" 
16 :R2*R1 RA*R3 ОРОКЕ 135,2 
17 :R1*R2 R3*RA 42K "ХХХ 
18 :R3*R1 RA*R2 12K 2XXX IMP INT IMP FPT 
19 :R1*R3 R2*RA 8K 1XXX ЗІМР ЕРТ 
OCLEAR XXXX 
о 
LIJN CTRL COLOR LIJN CTRL COLOR о ЫН 
23 BFEF BFEE 11 ВЧА? ВЗАБ оРОКЕ 135.2 
22 ВЕБЗ ВЕБВ 10 8921 B920 й 
21 BEES BEEZ 9 8898 B89A CTRL&COLOR BYTES IN A-MODE 
20 BE5D BESC 8 BB15 B814 MODE CTRL COLOR LIJN 
19 ВОО? BDD6 y B78F B78E 1А/2А ВАЕ? ВАЕБ 3 
18 Вр51 BD50 6 8709 8708 BAB1 BABO 2 
17 BCCB BCCA 5 8683 8682 8908 вара 1 
16 8045 BC44 4 B5FD BSFC 8955 8954 0 
15 BBBF ВВВЕ 8 8577 8576 ЗА/АА АСЗ ACD2 3 
14 BB39 8838 2 B4F1 ВАРО AC4D АСАС 2 
~ 13 ВАВЗ ВАВ2 1 B46B В4БА ABC? АВСБ 1 
12 ВА20 BA2C 0 B3E5 B3E4 AB41 AB40 D 
5A/6A 7557 7556 3 
FDOO b2 page signal FFOO ser.inp.buff 7401 7400 2 
b3 serial out гду FFD1 60-6 keyb.inp. 744B 744A 4 
b4 right paddle 67 in? ОСЕ TACS 7304 0 
b5 left paddle FFO2 Interr.reg. 
Бб random data FFO3 51 frame error 
b7 cass, input b2 overrun error 
2001 Trigger paddle Б5 rec.buf.loaded FFOG TIMER D 
2004 0-3 volume ы, Б4 trans.buf.empty ЕЕПА TIMER 1 
. 4-7 volume ch.2(1 : FFOB TIM 2 
2005 0-3 volume ch.3(2) FFO4 COMMAND REGISTER 1: ША - 
4-7 volume noise FFO5 BAUD RATE REGISTER 
2006 bO cass.out FFO6 ser.out buf. FFOD TIMER 4 
b1/2 paddle select FF07 keyb.output 8253 
03 paddle enable FFO8 interr.mask reg. CH O FCOO/FCO1 
b4 cass motor 1 CH 1 FCO2/FCO3 
b5 cass motor 2 TEST EVENT CH 2 FCO4/FCOS 


b6/7 ROM BANK SWITCH 


PEEK(ÉéFDOO) ТАМО 32 
РЕЕК(ёЕПО0) ТАМО 16 
РЕЕК (62000) ТАМО 48 


STATUS FCO6/FCO7 


